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PROVISIONAL SPECIFICATION 



Invention Title: Demodulation of a multi-level quadrature amplitude 

modulation signal 



The invention is described in the following statement: 



2 

DEMODULATION OF A MULTI-LEVEL QUADRATURE 
AMPLITUDE MODULATION SIGNAL 

The present invention relates generally to the demodulation of quadrature 
amplitude modulation (QAM) signals, and in particular to the determination of an 
5 integer value, representative of the magnitude of an orthogonal component of a 
quadrature amplitude modulation symbol, used in the calculation of a threshold 
value(s) for efficient demodulation of the signal. The invention has particular 
application to code division multiple access and other spread spectrum receivers, 
and it will be convenient to describe the invention in relation to that application. It 
10 is to be appreciated however, that the invention is not limited to use in this 
application only. 

At the heart of a QAM demodulator is a device that reconverts each received 
symbol back to its original digital data representation. In an ideal scenario, the 
received symbols will have a constellation where the coordinates for all symbols 

15 within the constellation are well defined. In this case, it would be possible to 
determine the equivalent data representation of each received symbol by 
determining the relative position of the symbol within the constellation using a 
preset threshold value(s) as depicted in Figure 1 

However, in the presence of noise and fading commonly experienced in the 

20 transmission media, the received constellation will be dispersed as depicted in 
Figure 2. The threshold value needed to perform the demodulation will also vary 
with channel condition. As a means to having an adaptive demodulator, techniques 
to derive the threshold value required to perform the demodulation which analyses 
the histogram of |I| and |Q| (the magnitude of the I and Q components) of received 

25 symbols have been proposed 

An example of a histogram of received symbols is depicted in Figure 3 to 
illustrate how the threshold value required to demodulate the received symbols may 
be derived from the histogram. In this figure, the histogram has been limited to 
some maximum amplitude A max which may be predetermined. A hardware 
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implementation capable of building such a histogram in its internal memory 
representation will need to be able to determine the associated bin/bar in the 
histogram given the amplitude of an I or a Q component. 

The task of determining the associated bin/bar in the histogram given an 
amplitude, A, and the maximum amplitude for the histogram, A max , can be stated 
mathematically as the need to determine the value k representative of an orthogonal 
component of a received QAM modulated symbol which satisfies the following 
condition, where W is A max divided by the resolution of histogram (i.e., the number 
ofbins/bars). 

Wxk^A < Wx(k+ 1) 
An added complexity is created by the fact that A, A max and W are commonly 

floating point numbers. 

From the perspective of a spread spectrum mobile receiver, an optimal 
design in terms of silicon area and power consumption is highly desirable. An 
effective design that is capable of computing k with the least delay (i.e., within the 
shortest possible clock period) is also highly desirable. 

One aspect of the invention provides a device for determining k 
representative of the magnitude A of an orthogonal component of a Quadrature 
Amplitude Modulation (QAM) symbol, including: 
20 multi-stage binary search circuitry for conducting a multi-stage binary search 

for the value of A between predetermined maximum and minimum values A mox and 
A min , each stage producing a single bit binary output; and 

integer value construction circuitry for constructing the integer value k by 
juxtaposing the binary outputs from consecutive stages of the binary search, 
25 where W~ (A max - A mi „)/n, 

n equals 2' and i is an integer, 

A max is a maximum detectable level of the magnitude A, 

A mi „ is a minimum detectable level of the magnitude A, and 

W \s the incremental level between consecutive values of the integer value k. 



15 
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A device having these features advantageously avoids the need to carry out 
division operations, and facilitates an efficient hardware implementation which 
maximises the use of simple circuit elements such as adders, comparators, 

multiplexers and registers. 
5 In at least one embodiment, each orthogonal component sample and the 

predetermined maximum value A max are in a floating point format comprising a 
mantissa and an exponent. In this case, the circuitry may include exponent 
normalising circuitry for bit-shifting the mantissa until the exponent is identical to 
the exponent of the predetermined maximum value A max . 
10 Use of the exponent normalising circuitry enables comparisons between the 

orthogonal component samples and the predetermined maximum value A max to be 
made by the processing of integers only, without requiring floating point processing 
circuitry. 

In at least one embodiment, the predetermined minimum value A min is zero, 
15 and the multi-stage binary search circuitry includes a first stage search element and 
one or more subsequent stage search elements, the first stage search element 
including a bit shift block for determining the mid-point between the predetermined 

maximum value A max and zero. 

Each subsequent stage search elements may include an adder for determining 
20 the mid-point between upper and lower output values of a preceding search element. 

The first stage search element and subsequent stage search elements may 
each include a comparator for comparing respectively the midpoint between 
predetermined maximum and minimum values A^ and A mi „, and the midpoint 
between upper and lower output values of a preceding search element, wherein the 
25 integer value k is constructed by the integer value constructing circuitry from the 

outputs of the comparators. 

Another aspect of the invention provides a method for determining an integer 
value * representative of the magnitude A of an orthogonal component of a 
Quadrature Amplitude Modulation (QAM) symbol, the method including the steps 



Melboume\004410878 - Printed 17 December 2003 (10:24) 



5 

of: j 

(a) conducting a multi-stage binary search for the value of A between 
predetermined maximum and minimum values A max and A mim each stage producing 
a single binary output; and 
5 (b) constructing the integer value k by juxtaposing the binary outputs 

from consecutive stages of the binary search, 

where (A max - A min )ln y 

n equals 2 i and i is an integer, 

A max is a maximum detectable level of the magnitude A, 
10 A min is a minimum detectable level of the magnitude A, and 

Wis the incremental level between consecutive values of the integer value h 

The following description refers in more detail to the various features of the 
present invention. To facilitate an understanding of the invention, reference is made 
in the description to the accompanying drawings where the demodulation device is 
15 illustrated in a preferred embodiment. It is to be understood that the present 
invention is not limited though to the preferred embodiment as illustrated in the 
drawings. 

In the drawings: 

Figure 1 is a schematic diagram of an ideal 16 QAM received symbol 
20 constellation; 

Figure 2 is a schematic diagram showing a 16 QAM constellation in the 
presence of noise in the transmission medium; 

Figure 3 is a histogram of received symbols in a 16 QAM constellation; 

Figure 4 is a schematic diagram of a device for determining integer value, k 9 
25 representative of the magnitude of an orthogonal component of a QAM symbol, 
according to one embodiment of the present invention; 

Figure 5 is a schematic diagram of a first embodiment of a first stage search 
element; 

Figure 6 is a schematic diagram showing one embodiment of a subsequent 
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stage search element; 

Figure 7 is a representation of the manner in which integer value, k, 
representative of the magnitude of the I/Q components of a QAM symbol; 

Figure 8 is a schematic diagram of a second embodiment of first stage search 
5 element* 

Referring now to Figure 4, there is shown a device 5 for determining integer 
value, k, representative of the magnitude of an orthogonal component of a QAM 
symbol forming part of the an adaptive QAM demodulation device. The device 5 
includes an exponent normalising block 20, a multi stage binary search block 21 

10 and integer value constructing circuitry 22. The multi stage binary search circuitry 
21 includes a first stage search element 22 and subsequent stage search elements 23 
to 25. The integer value constructing circuitry includes registers 26 to 29 for 
storing binary outputs from consecutive stages of the binary search circuitry 21. 

The exponent normalising block 20 acts to compare the exponent of the 

15 floating point representation of the I/Q component to the exponent of a 
predetermine maximum value A max . The block 20 also acts to determine the 
absolute value for the input I/Q component and bit shift the mantissa representation 
of that component until its exponent is identical to the exponent for A mwc . In this 
way, the multi-stage binary search block 21 is reduced to an integer 

20 implementation, eliminating the need to perform floating point calculations. 

The output of the exponent normalisation block 20 and the mantissa of the 
predetermined maximum value A mwc are provided as inputs to the first stage search 
element 22 of the multi-stage binary search block 21. 

As can be seen in more detail in Figure 5, the first stage element 22 includes 

25 a one bit right shift block 30, a comparator 31 , and two multiplexers 32 and 33. The 
one bit right shift block 30 effectively performs a divide-by-two operation on the 
mantissa of the predetermined maximum value A max . In other words, A max jdiv_2 is 
connected to A ntax mantissa where the least significant bit of A max mantissa is not 
used and the most significant bit of A max jiivJ2 is set to 0. 
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The output of the one bit right shift block 30 is provided to the B input of the 
comparator 31. The normalised mantissa representation of the magnitude A, as 
output from the exponent normalisation block 20, is provided to the A input of the 
comparator 31. The predetermined maximum value A max is provided to one input of 
5 the multiplexer 32, whilst the predetermined minimum value A mim in this case 
having a value of 0, is input to one of the inputs of the multiplexer 33. The output 
of the one bit right shift block 30, namely the mantissa of the value A max divided by 
2, is supplied to the other input of both multiplexers 32 and 33. The output of the 
comparator 31 is provided to an enable input of the multiplexers 32 and 33. If the 

10 comparator 31 determines that the normalised mantissa of the magnitude A of the 
I/Q component is greater than one half of A maX7 then the binary string representative 
of the mantissa of A max is reproduced at the output of the multiplexer 32 and the 
binary string representative of one half of A max is transmitted by the multiplexer 33. 
Alternatively, if the value at the A input of the comparator 31 is less than the 

15 value of the B input, the binary string representative of the value one half of A max is 
transmitted by the multiplexer 32, and a binary string of 0 value is transmitted by 
the multiplexer 33. 

The output of the multiplexers 32 and 33 are provided as inputs to the second 
stage search element 23. A more detailed view of the second and subsequent stage 

20 of the search elements is shown in Figure 6. The search elements 23, 24 and 25 
include registers 40 and 41 respectively for storing the outputs of the two 
multiplexes from a preceding search element, and adder block 42, a comparator 43 
and two multiplexers 44 and 45. The two values input to the registers 40 and 41 
from a preceding search stage correspond to upper and lower values between which 

25 the magnitude A of the input I/Q component is located. In accordance with known 
binary search techniques, the range between the upper and lower output values 
stored in the registers 40 and 41 corresponds to half the range of the upper and 
lower output values from a preceding search element (or in the case of the first stage 
search element the predetermined maximum and minimum values A max and A min ). 
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The outputs of the two registers 40 and 41 are provided to the inputs of the 
block 42, which implements a function 



where h and / are the two values stored in the registers 40 and 41 . In fact, the block 



described first stage search element, the divide-by-two operation performed after 
the addition of h to / is nothing more than a one bit right shift operation that is 
implemented by the physical connections made to the adder. 

The block 42 acts to determine the mid point between the values stored in the 
10 registers 40 and 41, and provides this value to the B of the comparator 43. The 
normalised value of the magnitude A of the input I/Q component is provided to the 
other A input of the comparator 43. Depending upon that normalised value is 
greater than the mid point determined by the block 42, or less than that mid point 
value, the multiplexes 44 and 45 will respectively output upper and lower values 
15 corresponding either to the value stored in the register 40 and the mid point as 

determined by the block 42, or the mid point and the value stored in the register 41 . 

As can be seen in Figure 4, the binary output from each of the comparators in 
the search elements 22 to 25 are stored in registers 26 to, 29. By juxtaposing the 
binary output from consecutive stages of the binary search circuitry, and integer 
20 value k representative of the magnitude A of the input I/Q component is derived. 

Prior to examining at how the above desired hardware implementation 
generates the integer value k, given A and A maxy consider first the binary value for k 
and its relation to W and A max as depicted in Figure 7. An important aspect of the 
present invention is that the integer value, k, can be constructed whilst the region 
25 where A lies within the range from 0 to A max is being refined and searched for in a 
binary search fashion. A prerequisite for the previous statement to be valid is that 
AjnJn where the value for n satisfies the condition n e { 2' | i e IN }. 
In other words, if the range from 0 to A max is divided into n equal regions, the 
integer value k will have a bit width of / where n = 2 1 and the most significant bit of 
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42 implements this function with a simple adder. As was the case in the above 
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k is I if A >(A mQX + 0)/2. It is 0 otherwise. After having determined if A lies on the 
upper or lower half in the full range from 0 to A max , the most significant bit of the 
remaining (/ ~ 1) undefined bits in k can again be determined in the same manner by 
determining if it is in the upper or lower quarter in the half that it is known to be in. 
5 This process is repeated for each of the remaining (i - 2) bits of k halving the search 
range in each subsequent search in each subsequent search element Recall that 
W= A m Jn and n e { 2 \ i e IN }, This being the case, the binary value for k for 
each of the n sub-regions will be such that the most significant bit of k has a value 1 
on the top half of the scale from 0 to A max . It has a value 0 on the lower half. 

10 Within each of these halves, the next less significant bit of k will again have the 
value 1 on the upper quarter and 0 on the lower. The same is again applicable to the 
next less significant bit of k over each of the 4 quarters. 

Given the exponent normalised magnitude A of an VQ component, the 
integer value k which satisfies the condition Wxk<>A<W><(k+l) can be 

15 determined by first determining if A lies on the upper or lower half between 0 to 
A max . As described above, the most significant bit of A: will have a value 1 if it is. 
Accordingly, the design of the first stage search element 22 is such that it 
determines if A >A max /2. The most significant bit of A: is set to 1 if it is. It will be 
set to a 0 otherwise. Having determined if A lies on the upper or the lower halves, 

20 the upper and lower bound of the halves A lies in is then multiplexed to the search 
element in the following stage. This search element 22 will first determine the 
mid-point between the upper and lower limits and again checking if A lies above or 
below this mid-point setting the next least significant bit of k accordingly. The 
upper and lower limit for the search element for the next stage is also set in the 

25 same way. This is repeated for the bit width of L In other words, the bit value' of A: 
is being constructed as the region where A lies in the scale from 0 to A max is being 
refined and searched for in a binary search fashion. 

As an example, consider a case where A max = 0.01 101 1 1000 x 2 1 , n = 16 and 
an I/Q component of -0.10101 10100 x 2~ l . n having the value 16 means that / is 4 
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which in turn implies that k is represented by a 4 bit binary number and that the 



corresponding implementation will be a 4-stage search-element pipeline. 

Assume for the purpose of this illustration that the mantissa for A max has a 
binary representation of 01 101 1 1000. The value for A at the output of the exponent 
5 normalisation block 20 would then be 0.0010101101 and is simply represented in 
the implementation as 0010101 101. 

In the first stage search element 22, the mantissa representation for A max is 
connected to the comparator 31 such that A is compared to 0011011100. Since 
0010101101 is less than 0011011100, the output of the comparator 31 will be 0. 
10 This being the case, the output for the multiplexers 32 and 33 at the top and the 
bottom of the search element 22 will have the value 0011011100 and 0000000000 
respectively. These values, A and the output of the comparator 31 will be clocked 
into the respective registers 40 and 41 in the subsequent search element. 



function will have the value 0001 101 1 10 and the comparator 43 will then compare 
the value of A - 0010101101 to 0001101110. Since 0010101101 is greater than 
0001 101 1 10, the output of the comparator 43 will be a 1, Accordingly, the output 
of the multiplexers 44 and 45, at the top and the bottom for this second stage 
20 search-element 22 will be 001 101 1 100 and 0001 101 1 10 respectively. As with the 
previous stage, these values, A and the output of the comparator 43 will be clocked 
into the respective registers 40 and 41 in the subsequent stage 24. The previously 
clocked most significant bit of k derived by the previous stage will also be clocked 
into the next stage. 

25 In a similar manner, A = 0010101 101 is compared to 0010100101 and since 

A is greater than this value, the output of the comparator will be set to 1 
multiplexing the values, 001 101 1 100 and 0010100101 at the output of the top and 
bottom muxes of this stage. At the final stage, the value of A is compared with 



The output of the block 42 implementing the 



15 
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0011000000 and since A is smaller than this value, the output of the comparator is 
set to 0. Thus giving a binary value of 01 10 for the value of k. 

It will be noted that the value for Wneed not be calculated to determine the 
value for k. Also, it will be appreciated the two multiplexes in the final 
5 search-element are redundant and may be removed from the circuit design. 

Moreover, being structured in this example as a 4-stage pipeline, it will take 4 clock 
cycles to fill the pipeline and to obtain the first k value- Once the pipeline is filled, 
it will be able to process 1 input I/Q component data per clock cycle. 

Figure 8 shows a detailed view of an alternative embodiment of the first 

10 stage search element 22, In this alternative embodiment, the first stage search 
element 50 includes a comparator 52 and multiplexers 53 and 54 identical in 
operation to those described in relation to Figure 5. However, in this embodiment 
the initial value of the mantissa of the predetermined minimum value A min is 
non-zero, and as a consequence the one bit right shift operation block 30 is replaced 

15 by an adder 5 1 operating in the same manner as the adder 42 described in relation to 
Figure 6. Moreover, it will be necessary to derive a normalised exponent of the 
predetermined minimum value A min in the same manner as described above in 
relation to the predetermined maximum value A max . 

Those skilled in the art will appreciate that there may be many modifications 

20 and variations of the configuration described above which are within the scope of 
the present invention. 

DATED this 1 7 December 2003 
FREEHILLS CARTER SMITH BEADLE 
25 Patent Attorneys for the Applicant 

NEC AUSTRALIA PTY LTD 
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